#include<bits/stdc++.h>
using namespace std;
#define all(x) (x).begin(),(x).end()
#define rall(x) (x).rbegin(),(x).rend()
const int N=2e5+10;
#define INF 0x3f3f3f3f;
typedef long long int ll;
#define close(); std::ios::sync_with_stdio(false);cin.tie(0),cout.tie(0);
//----------------------------------------------------------------------------//

void solve()
{
	int n,B,x,y;
	cin>>n>>B>>x>>y;
	ll sum=0,cur=0;
	for(int i=1;i<=n;i++)
	{
		if(cur+x<=B) cur+=x;
		else cur-=y;
		sum+=cur;
	}
	cout<<sum<<'\n';
}
//如果前一个+x到大于B后一个则不能+x,只能减去y,否则加x,这样可以贪心到最大

int main()
{
	close();
	int T; cin>>T;
	while (T--) solve();
	return 0;
}